کانکتور مخصوص کابلهای Twisted Pair که برای اتصال به شبکههای اترنت مورد استفاده قرار میگیرد.
جدول هش (Hash Table) یک ساختار دادهای است که برای ذخیرهسازی دادهها به شکلی کارآمد و سریع طراحی شده است. این ساختار داده با استفاده از یک تابع هش، که دادهها را به اندیسهای خاصی نگاشت میکند، به سرعت به جستجو، اضافه کردن، و حذف دادهها پرداخته و زمان دسترسی را کاهش میدهد.
در جدول هش، هر داده به یک کلید (Key) و یک مقدار (Value) متصل است. کلید توسط تابع هش به یک موقعیت خاص (یا ایندکس) در آرایه اشاره میکند. سپس دادههای مرتبط در آن موقعیت ذخیره میشوند. یکی از ویژگیهای جدول هش این است که امکان دسترسی به دادهها با زمان ثابت O(1) فراهم میشود، به شرط آنکه تابع هش به خوبی طراحی شده باشد و برخورد (collision) نداشته باشیم.
در صورتی که دو کلید با استفاده از تابع هش به یک موقعیت مشابه نگاشت شوند، یک برخورد رخ میدهد. برای حل این مشکل، از روشهایی مانند زنجیرهای (Chaining) و بازپرسازی خطی (Linear Probing) استفاده میشود.
در اینجا یک پیادهسازی ساده از جدول هش در زبان Python آورده شده است:
class HashTable:
def __init__(self, size):
self.size = size
self.table = [None] * size
def hash_function(self, key):
return hash(key) % self.size
def insert(self, key, value):
index = self.hash_function(key)
self.table[index] = value
def search(self, key):
index = self.hash_function(key)
return self.table[index]
def delete(self, key):
index = self.hash_function(key)
self.table[index] = None در این کد، جدول هش به صورت یک آرایه از اندازه مشخص شده ساخته میشود. تابع hash_function از تابع hash() برای محاسبه ایندکس استفاده میکند. سپس، دادهها از طریق متدهای insert، search و delete در جدول ذخیره، جستجو و حذف میشوند.
در زبان Java، پیادهسازی جدول هش به شکل زیر است:
import java.util.LinkedList; public class HashTable {
private LinkedList<Entry>[] table;
private int size;
public HashTable(int size) {
this.size = size;
table = new LinkedList[size];
}
private int hashFunction(String key) {
return key.hashCode() % size;
}
public void insert(String key, String value) {
int index = hashFunction(key);
if (table[index] == null) {
table[index] = new LinkedList<>();
}
table[index].add(new Entry(key, value));
}
public String search(String key) {
int index = hashFunction(key);
if (table[index] != null) {
for (Entry entry : table[index]) {
if (entry.key.equals(key)) {
return entry.value;
}
}
}
return null;
}
public void delete(String key) {
int index = hashFunction(key);
if (table[index] != null) {
table[index].removeIf(entry -> entry.key.equals(key));
}
}
private class Entry {
String key;
String value;
Entry(String key, String value) {
this.key = key;
this.value = value;
}
} } در اینجا، از یک آرایه از لیستهای پیوندی (LinkedList) برای حل برخوردها استفاده شده است. هر ایندکس در آرایه به یک لیست پیوندی اشاره دارد که چندین عنصر ممکن است در آن ذخیره شوند، به این ترتیب با برخوردها به درستی مقابله میشود.
یکی از مزایای بزرگ جدول هش، زمان جستجو و دسترسی سریع آن است. با این حال، کارایی آن به طراحی تابع هش بستگی دارد. اگر تابع هش به درستی طراحی نشده باشد، تعداد برخوردها افزایش یافته و کارایی کاهش مییابد. همچنین، در صورتی که جدول هش بیش از حد پر شود، ممکن است نیاز به بازسازی جدول و افزایش اندازه آن باشد.
برای اطلاعات بیشتر، میتوانید از سایت saeidsafaei.ir و اسلایدهای محمد سعید صفایی بهرهبرداری کنید.
در این مبحث، به مقدمهای بر برنامهنویسی پرداخته و مفاهیم اساسی آن شامل تعریف برنامهنویسی، اهمیت برنامهنویسی، روشهای ترجمه کد، انواع زبانهای برنامهنویسی، و مهارتها و محیطهای برنامهنویسی بررسی میشود. هدف این جلسه، آشنایی با اصول پایهای برنامهنویسی و درک نحوه انتخاب زبان و محیط مناسب برای نوشتن برنامههای کاربردی است.
کانکتور مخصوص کابلهای Twisted Pair که برای اتصال به شبکههای اترنت مورد استفاده قرار میگیرد.
سینتسایزر صدا به سیستمهایی اطلاق میشود که از الگوریتمهای هوش مصنوعی برای تولید صدای طبیعی و مشابه انسان استفاده میکنند.
ساخت دیجیتال به استفاده از فناوریهای دیجیتال برای طراحی و ساخت محصولات فیزیکی و مدلهای پیچیده اطلاق میشود.
کد شیء به کدی اطلاق میشود که پس از ترجمه توسط کامپایلر از کد منبع به زبان ماشین تبدیل شده است. این کد آماده اجرا است.
حالت انتقال داده یک طرفه که در آن فقط یک دستگاه میتواند دادهها را ارسال کند یا دریافت کند.
جراحی رباتیک به استفاده از رباتها برای انجام عملهای جراحی با دقت و کنترل بالا اطلاق میشود.
هوش مصنوعی عمومی (AGI) به سیستمهایی اطلاق میشود که قابلیتهای شناختی مشابه انسانها را دارند و قادر به انجام انواع مختلف وظایف هستند.
محاسبات ابری بومی به استفاده از معماریهای ابری برای توسعه و اجرای برنامهها گفته میشود که مقیاسپذیر، انعطافپذیر و خودکار هستند.
زیرساخت فیزیکی که برای اتصال اجزای مختلف داخلی دستگاهها مانند سوییچها و روترها استفاده میشود.
میزان صحت دادهها و تاریخچهای که نشان میدهد دادهها از کجا آمدهاند، چه تغییراتی بر آنها اعمال شده و چه کسانی آنها را تغییر دادهاند.
متغیر سراسری متغیری است که در خارج از توابع و بلوکهای کد تعریف میشود و در سراسر برنامه قابل دسترسی است.
حافظه محلی است که دادهها و دستورات برنامهها در آن ذخیره میشود. این حافظه میتواند به صورت حافظه موقت (RAM) یا دائمی (هارد دیسک) باشد.
توابع هش رمزنگاری به توابع ریاضی اطلاق میشود که دادهها را به یک رشته ثابت طول تبدیل میکنند و برای امنیت دادهها استفاده میشوند.
اخلاق هوش مصنوعی به بررسی چالشها و مسائل اخلاقی مرتبط با استفاده از AI میپردازد.
آندر فلو زمانی رخ میدهد که مقدار عددی مورد نظر از حداقل مقدار قابل نمایش در سیستم کمتر باشد.
ماتریس یک نوع آرایه دو بعدی است که برای انجام عملیاتهای ریاضی و جبر خطی به کار میرود.
مدل ارتباطی که در آن دو دستگاه بهطور مستقیم به یکدیگر متصل میشوند.
الگوریتمهایی هستند که برای ترتیبدهی دادهها به روشهای مختلف از جمله مرتبسازی صعودی و نزولی استفاده میشوند.
حلقه do-while مشابه با while است، با این تفاوت که ابتدا دستورالعملها اجرا میشود و سپس شرط بررسی میشود. بنابراین این حلقه حداقل یک بار اجرا میشود.
زمان دسترسی به حافظه که مدت زمانی است که پردازنده نیاز دارد تا دادهای را از حافظه بخواند یا در آن بنویسد.
یک نوع NAT که از پورتهای مختلف برای ترجمه آدرسهای IP خصوصی به یک آدرس عمومی استفاده میکند.
روش ارتباطی یک به یک که در آن یک دستگاه دادهها را به دستگاه دیگر ارسال میکند.
به هر جهش یا انتقال دادهها از یک دستگاه به دستگاه دیگر در شبکه گفته میشود.
محاسبات عصبیشکل به محاسباتی گفته میشود که مدلسازی مغز انسان را تقلید میکند تا راهحلهایی مشابه سیستمهای عصبی طبیعی ایجاد کند.
اتوماسیون شناختی به فرآیندهایی اطلاق میشود که ترکیب شدهاند تا فرآیندهای پیچیده تجاری را بهطور خودکار و با استفاده از یادگیری ماشین انجام دهند.
نسل پنجم شبکههای مخابراتی (5G) سرعت اینترنت، اتصال بیشتر و تأخیر کمتری را نسبت به نسلهای قبلی ارائه میدهد.
استاندارد شبکههای بیسیم شخصی که به طور خاص برای ارتباطات بلوتوثی استفاده میشود.
اضافه بار یا اوورفلو زمانی رخ میدهد که سیستم محاسباتی نمیتواند عددی بزرگتر از ظرفیت ذخیرهسازی خود را پردازش کند.
بلاکچین برای اینترنت اشیاء به استفاده از بلاکچین برای اتصال دستگاههای IoT و مدیریت دادهها بهصورت امن و شفاف اشاره دارد.
پروتکلی در لایه 2 برای جلوگیری از حلقههای شبکهای و مدیریت مسیرهای انتقال دادهها.
اتوماسیون هوشمند به استفاده از فناوریهای AI برای خودکارسازی فرآیندها و انجام کارهای پیچیده اشاره دارد.
خودروهای خودران به خودروهایی اطلاق میشود که میتوانند بدون دخالت انسان حرکت کنند و تصمیمات رانندگی را اتخاذ کنند.
لایهای که مسئول مدیریت نشستها و ارتباطات بین برنامههای کاربردی است.
کد استاندارد برای تبادل اطلاعات متنی است که برای هر حرف، عدد یا نماد یک کد باینری مشخص در نظر میگیرد.
دیباگینگ به فرآیند پیدا کردن و رفع اشکالات در کد برنامه گفته میشود. این فرآیند برای اطمینان از صحت عملکرد الگوریتم و جلوگیری از بروز خطاها ضروری است.